
    using System;
    using System.Collections.Generic;
    using System.Data.SqlClient;
    using ADL;
    using ADL.ProyectosTableAdapters;
    using AEL.APU;
    using BEL;
    
    namespace CEL.APU
    {
    /// <summary>
    /// Acceso a la base de datos
    /// Modulo:Proyectos 
    /// Tabla:Apu_Pedido_Estructura
    /// </summary>
    public class DO_Apu_Pedido_Estructura
    {
    #region Adapter
    private Apu_Pedido_EstructuraTableAdapter _Adapter;
    /// <summary>
    /// Acceso al Table Adapter de la capa ADL
    /// </summary>
    public Apu_Pedido_EstructuraTableAdapter Adapter
    {
    get
    {
    if (_Adapter == null)
    _Adapter = new Apu_Pedido_EstructuraTableAdapter();
     return _Adapter;
     }
     }
    #endregion
    #region Obtención de datos
    //Obtencion de datos
    /// <summary>
    /// Obtiene todos los datos de la tabla Apu_Pedido_Estructura
    /// </summary> 
    /// <returns>Lista de objetos Apu_Pedido_Estructura</returns> 
    public List <Apu_Pedido_Estructura> Get ( Scope s )
    {
    string llamada = "";
    List <Apu_Pedido_Estructura> lista= new List <Apu_Pedido_Estructura> ();
    //Extrae los datos
    if(s != null)
    {
    Proyectos.Apu_Pedido_EstructuraDataTable tabla = 
    Adapter.Get (s.Ver_Version_Id);
    //Cuenta  el número  de registros de la tabla
    int numeroRegistros = tabla.Count;
    llamada = "Nombre del Método Utilizado: Get "  + "Parametros  Enviados en el Método: s "  + " Nombre del Store Procedure: " + " Apu_Pedido_Estructura_Get "+ " Número de Registros: " + numeroRegistros;
    //Carga en la lista
      foreach (Proyectos.Apu_Pedido_EstructuraRow fila in tabla)
      lista.Add(new Apu_Pedido_Estructura(
      
    fila.Id,
    fila.Codigo,
    fila.Estado,
    fila.Apu_Estructura_Id,
    fila.Cantidad,
    fila.Fecha_Creacion,
    fila.Creacion_Per_Personal_Id,
    fila.Fecha_Update,
    fila.Update_Per_Personal_Id,
    fila.Apu_Pedido_Id,
    fila.Apu_Estructura_Codigo,
    fila.Apu_Estructura_Nombre,
    fila.Apu_Estructura_Unidad,
    fila.Apu_Orden_Id,
    fila.Apu_Orden_Codigo,
    fila.Apu_Orden_Nombre,
    fila.Creacion_Per_Personal_Codigo,
    fila.Creacion_Per_Personal_Nombre,
    fila.Update_Per_Personal_Codigo,
    fila.Update_Per_Personal_Nombre,
    fila.Costo,
    fila.Total,
    fila.Estado_Nombre));
      }
      //Devuleve la Lista
      return lista;
      }
      public List <Apu_Pedido_Estructura> GetByCantidad( Scope s , decimal Cantidad)
          {
          string llamada = "";
          List <Apu_Pedido_Estructura> lista= new List <Apu_Pedido_Estructura> ();
          //Extrae los datos
          if(s != null)
          {
          Proyectos.Apu_Pedido_EstructuraDataTable tabla = 
          Adapter.GetByCantidad(s.Ver_Version_Id, Cantidad);
          //Cuenta  el número  de registros de la tabla
          int numeroRegistros = tabla.Count;
          llamada = "Nombre del Método Utilizado: " + " GetByCantidad" + " Parametros  Enviados en el Método: "+ "," + " s.Ver_Version_Id : " + s.Ver_Version_Id+ "," + " Cantidad : " + Cantidad  + " Nombre del Store Procedure: " + "dbo.Apu_Pedido_Estructura_ByCantidad " + " Número de Registros: " + numeroRegistros;
          //Carga en la lista
          foreach (Proyectos.Apu_Pedido_EstructuraRow fila in tabla)
          lista.Add(new Apu_Pedido_Estructura(
          
    fila.Id,
    fila.Codigo,
    fila.Estado,
    fila.Apu_Estructura_Id,
    fila.Cantidad,
    fila.Fecha_Creacion,
    fila.Creacion_Per_Personal_Id,
    fila.Fecha_Update,
    fila.Update_Per_Personal_Id,
    fila.Apu_Pedido_Id,
    fila.Apu_Estructura_Codigo,
    fila.Apu_Estructura_Nombre,
    fila.Apu_Estructura_Unidad,
    fila.Apu_Orden_Id,
    fila.Apu_Orden_Codigo,
    fila.Apu_Orden_Nombre,
    fila.Creacion_Per_Personal_Codigo,
    fila.Creacion_Per_Personal_Nombre,
    fila.Update_Per_Personal_Codigo,
    fila.Update_Per_Personal_Nombre,
    fila.Costo,
    fila.Total,
    fila.Estado_Nombre));
          }
          //Realiza la auditoria
          Auditar.Registro(s, llamada, lista, Textos._AUDITAR_ACCION_SELECT_SEL);
          //Devuleve la Lista
          return lista;
          }
          public List <Apu_Pedido_Estructura> GetByCodigo( Scope s , string Codigo)
          {
          string llamada = "";
          List <Apu_Pedido_Estructura> lista= new List <Apu_Pedido_Estructura> ();
          //Extrae los datos
          if(s != null)
          {
          Proyectos.Apu_Pedido_EstructuraDataTable tabla = 
          Adapter.GetByCodigo(s.Ver_Version_Id, Codigo);
          //Cuenta  el número  de registros de la tabla
          int numeroRegistros = tabla.Count;
          llamada = "Nombre del Método Utilizado: " + " GetByCodigo" + " Parametros  Enviados en el Método: "+ "," + " s.Ver_Version_Id : " + s.Ver_Version_Id+ "," + " Codigo : " + Codigo  + " Nombre del Store Procedure: " + "dbo.Apu_Pedido_Estructura_ByCodigo " + " Número de Registros: " + numeroRegistros;
          //Carga en la lista
          foreach (Proyectos.Apu_Pedido_EstructuraRow fila in tabla)
          lista.Add(new Apu_Pedido_Estructura(
          
    fila.Id,
    fila.Codigo,
    fila.Estado,
    fila.Apu_Estructura_Id,
    fila.Cantidad,
    fila.Fecha_Creacion,
    fila.Creacion_Per_Personal_Id,
    fila.Fecha_Update,
    fila.Update_Per_Personal_Id,
    fila.Apu_Pedido_Id,
    fila.Apu_Estructura_Codigo,
    fila.Apu_Estructura_Nombre,
    fila.Apu_Estructura_Unidad,
    fila.Apu_Orden_Id,
    fila.Apu_Orden_Codigo,
    fila.Apu_Orden_Nombre,
    fila.Creacion_Per_Personal_Codigo,
    fila.Creacion_Per_Personal_Nombre,
    fila.Update_Per_Personal_Codigo,
    fila.Update_Per_Personal_Nombre,
    fila.Costo,
    fila.Total,
    fila.Estado_Nombre));
          }
          //Realiza la auditoria
          Auditar.Registro(s, llamada, lista, Textos._AUDITAR_ACCION_SELECT_SEL);
          //Devuleve la Lista
          return lista;
          }
          public List <Apu_Pedido_Estructura> GetByFechaCreacion( Scope s , DateTime Fecha)
          {
          string llamada = "";
          List <Apu_Pedido_Estructura> lista= new List <Apu_Pedido_Estructura> ();
          //Extrae los datos
          if(s != null)
          {
          Proyectos.Apu_Pedido_EstructuraDataTable tabla = 
          Adapter.GetByFechaCreacion(s.Ver_Version_Id, Fecha);
          //Cuenta  el número  de registros de la tabla
          int numeroRegistros = tabla.Count;
          llamada = "Nombre del Método Utilizado: " + " GetByFechaCreacion" + " Parametros  Enviados en el Método: "+ "," + " s.Ver_Version_Id : " + s.Ver_Version_Id+ "," + " Fecha : " + Fecha  + " Nombre del Store Procedure: " + "dbo.Apu_Pedido_Estructura_ByFechaCreacion " + " Número de Registros: " + numeroRegistros;
          //Carga en la lista
          foreach (Proyectos.Apu_Pedido_EstructuraRow fila in tabla)
          lista.Add(new Apu_Pedido_Estructura(
          
    fila.Id,
    fila.Codigo,
    fila.Estado,
    fila.Apu_Estructura_Id,
    fila.Cantidad,
    fila.Fecha_Creacion,
    fila.Creacion_Per_Personal_Id,
    fila.Fecha_Update,
    fila.Update_Per_Personal_Id,
    fila.Apu_Pedido_Id,
    fila.Apu_Estructura_Codigo,
    fila.Apu_Estructura_Nombre,
    fila.Apu_Estructura_Unidad,
    fila.Apu_Orden_Id,
    fila.Apu_Orden_Codigo,
    fila.Apu_Orden_Nombre,
    fila.Creacion_Per_Personal_Codigo,
    fila.Creacion_Per_Personal_Nombre,
    fila.Update_Per_Personal_Codigo,
    fila.Update_Per_Personal_Nombre,
    fila.Costo,
    fila.Total,
    fila.Estado_Nombre));
          }
          //Realiza la auditoria
          Auditar.Registro(s, llamada, lista, Textos._AUDITAR_ACCION_SELECT_SEL);
          //Devuleve la Lista
          return lista;
          }
          public List <Apu_Pedido_Estructura> GetById( Scope s , string Id)
          {
          string llamada = "";
          List <Apu_Pedido_Estructura> lista= new List <Apu_Pedido_Estructura> ();
          //Extrae los datos
          if(s != null)
          {
          Proyectos.Apu_Pedido_EstructuraDataTable tabla = 
          Adapter.GetById(s.Ver_Version_Id, Id);
          //Cuenta  el número  de registros de la tabla
          int numeroRegistros = tabla.Count;
          llamada = "Nombre del Método Utilizado: " + " GetById" + " Parametros  Enviados en el Método: "+ "," + " s.Ver_Version_Id : " + s.Ver_Version_Id+ "," + " Id : " + Id  + " Nombre del Store Procedure: " + "dbo.Apu_Pedido_Estructura_ById " + " Número de Registros: " + numeroRegistros;
          //Carga en la lista
          foreach (Proyectos.Apu_Pedido_EstructuraRow fila in tabla)
          lista.Add(new Apu_Pedido_Estructura(
          
    fila.Id,
    fila.Codigo,
    fila.Estado,
    fila.Apu_Estructura_Id,
    fila.Cantidad,
    fila.Fecha_Creacion,
    fila.Creacion_Per_Personal_Id,
    fila.Fecha_Update,
    fila.Update_Per_Personal_Id,
    fila.Apu_Pedido_Id,
    fila.Apu_Estructura_Codigo,
    fila.Apu_Estructura_Nombre,
    fila.Apu_Estructura_Unidad,
    fila.Apu_Orden_Id,
    fila.Apu_Orden_Codigo,
    fila.Apu_Orden_Nombre,
    fila.Creacion_Per_Personal_Codigo,
    fila.Creacion_Per_Personal_Nombre,
    fila.Update_Per_Personal_Codigo,
    fila.Update_Per_Personal_Nombre,
    fila.Costo,
    fila.Total,
    fila.Estado_Nombre));
          }
          //Realiza la auditoria
          Auditar.Registro(s, llamada, lista, Textos._AUDITAR_ACCION_SELECT_SEL);
          //Devuleve la Lista
          return lista;
          }
          public List <Apu_Pedido_Estructura> GetByPedido( Scope s , string Apu_Pedido_Id)
          {
          string llamada = "";
          List <Apu_Pedido_Estructura> lista= new List <Apu_Pedido_Estructura> ();
          //Extrae los datos
          if(s != null)
          {
          Proyectos.Apu_Pedido_EstructuraDataTable tabla = 
          Adapter.GetByPedido(s.Ver_Version_Id, Apu_Pedido_Id);
          //Cuenta  el número  de registros de la tabla
          int numeroRegistros = tabla.Count;
          llamada = "Nombre del Método Utilizado: " + " GetByPedido" + " Parametros  Enviados en el Método: "+ "," + " s.Ver_Version_Id : " + s.Ver_Version_Id+ "," + " Apu_Pedido_Id : " + Apu_Pedido_Id  + " Nombre del Store Procedure: " + "dbo.Apu_Pedido_Estructura_ByPedido " + " Número de Registros: " + numeroRegistros;
          //Carga en la lista
          foreach (Proyectos.Apu_Pedido_EstructuraRow fila in tabla)
          lista.Add(new Apu_Pedido_Estructura(
          
    fila.Id,
    fila.Codigo,
    fila.Estado,
    fila.Apu_Estructura_Id,
    fila.Cantidad,
    fila.Fecha_Creacion,
    fila.Creacion_Per_Personal_Id,
    fila.Fecha_Update,
    fila.Update_Per_Personal_Id,
    fila.Apu_Pedido_Id,
    fila.Apu_Estructura_Codigo,
    fila.Apu_Estructura_Nombre,
    fila.Apu_Estructura_Unidad,
    fila.Apu_Orden_Id,
    fila.Apu_Orden_Codigo,
    fila.Apu_Orden_Nombre,
    fila.Creacion_Per_Personal_Codigo,
    fila.Creacion_Per_Personal_Nombre,
    fila.Update_Per_Personal_Codigo,
    fila.Update_Per_Personal_Nombre,
    fila.Costo,
    fila.Total,
    fila.Estado_Nombre));
          }
          //Realiza la auditoria
          Auditar.Registro(s, llamada, lista, Textos._AUDITAR_ACCION_SELECT_SEL);
          //Devuleve la Lista
          return lista;
          }
          #endregion
    #region Operaciones con datos
    
    //Inserta
    /// <summary>
    /// Inserta el objeto en la tabla Apu_Pedido_Estructura
    /// </summary>
    /// <param name="s">Variables de ámbito como la versión y la sucursal</param>
    // <returns></returns>
    public string Insert(Scope s, Apu_Pedido_Estructura o)
    {
    // Genera un nuevo Id, codigo y estado.
    o.GenNewId(s.Int_Sucursal_Numero);
    o.GenCodigo(s.Ver_Version_Id);
    o.GenEstado();
    // Controla el error de clave primaria duplicada.
    o.Creacion_Per_Personal_Id = s.Per_Personal_Id;
    o.Update_Per_Personal_Id = s.Per_Personal_Id;
    o.Fecha_Creacion = DateTime.Now;
    o.Fecha_Update = DateTime.Now;
    try
    {
    Adapter.Insert(
    
          o.Id,
          o.Codigo,
          o.Apu_Estructura_Id,
          o.Cantidad,
          o.Fecha_Creacion,
          o.Creacion_Per_Personal_Id,
          o.Fecha_Update,
          o.Update_Per_Personal_Id,
          o.Apu_Pedido_Id,
          o.Estado
    );
    }
    catch (SqlException e)
    {
        Exception eCaso;
        Exception otroEX;
        switch (e.Number)
        {
            // Si el error es de violación PK, entonces repite.
            case 2627:
                string mensaje = e.Errors[0].Message;
                if (mensaje.StartsWith(
                       Textos._ERR_VIOLATION_UNIQUE_KEY)
                       )
                    return Insert(s, o);
                else
                {
                    if (e.Message.Contains(TXT_BDD._IX_Apu_Pedido_Estructura_Codigo))
                    {
                        eCaso = new Exception("");
                        otroEX = new Exception(TXT_Mensajes._MSJ32, eCaso);
                        throw (otroEX);
                    }

                    eCaso = new Exception(e.Message);
                    otroEX = new Exception(TXT_Mensajes._MSJ34, eCaso);
                    throw (otroEX);
                }
                break;
            default:
                eCaso = new Exception(e.Message);
                otroEX = new Exception(TXT_Mensajes._MSJ34, eCaso);
                throw (otroEX);
        }
    }
    //Control de Auditoria
    Auditar.Registro(s, o, Textos._AUDITAR_ACCION_INSERT);
    //Retorna el Id Insetado
     return o.Id;
    }
    // Borra
    /// <summary>
    /// Borra el objeto de la tabla Apu_Pedido_Estructura
    ///</summary>
     /// <param name="o">Objeto a actualizar</param>
    /// <returns></returns>
    public int Delete(Scope s,  Apu_Pedido_Estructura o)
    {
    int resultado = 0;
            try
            {
           resultado = Adapter.Delete(
    
          o.Id,
          o.Codigo,
          o.Apu_Estructura_Id,
          o.Cantidad,
          o.Fecha_Creacion,
          o.Creacion_Per_Personal_Id,
          o.Fecha_Update,
          o.Update_Per_Personal_Id,
          o.Apu_Pedido_Id,
          o.Estado
    );
       }
       catch (SqlException e)
       {
           Exception eCaso;
           Exception otroEX;

           eCaso = new Exception(e.Message);
           otroEX = new Exception(TXT_Mensajes._MSJ34, eCaso);
           throw (otroEX);
       }
    Auditar.Registro(s, o, Textos._AUDITAR_ACCION_DELETE);
    return resultado;
    }//Actualiza
    /// <summary>
    //Actualiza la tabla Apu_Pedido_Estructura
    /// </summary>
    /// <param name="o">Objeto que contiene la información a actualizar</param>
    /// <param name="original">Original para concurrencia optimista</param> 
    /// <returns></returns>
    public int Update(Scope s, Apu_Pedido_Estructura o, Apu_Pedido_Estructura original)
    {
     o.Creacion_Per_Personal_Id = s.Per_Personal_Id;
        o.Update_Per_Personal_Id = s.Per_Personal_Id;

   int resultado = 0;
            try
            {
                resultado = Adapter.Update(
    
          o.Id,
          o.Codigo,
          o.Apu_Estructura_Id,
          o.Cantidad,
          o.Fecha_Creacion,
          o.Creacion_Per_Personal_Id,
          o.Fecha_Update,
          o.Update_Per_Personal_Id,
          o.Apu_Pedido_Id,
          o.Estado,
          original.Id,
          original.Codigo,
          original.Apu_Estructura_Id,
          original.Cantidad,
          original.Fecha_Creacion,
          original.Creacion_Per_Personal_Id,
          original.Fecha_Update,
          original.Update_Per_Personal_Id,
          original.Apu_Pedido_Id,
          original.Estado
    
    );
            }
            catch (SqlException e)
            {
                Exception eCaso;
                Exception otroEX;
                if (e.Message.Contains(TXT_BDD._IX_Apu_Pedido_Estructura_Codigo))
                {
                    eCaso = new Exception("");
                    otroEX = new Exception(TXT_Mensajes._MSJ32, eCaso);
                    throw (otroEX);
                }

                eCaso = new Exception(e.Message);
                otroEX = new Exception(TXT_Mensajes._MSJ34, eCaso);
                throw (otroEX);
            }
    Auditar.Registro(s, o, Textos._AUDITAR_ACCION_UPDATE);
    return resultado;
    }
    #endregion
    }
    }
